package com.zzgc.modules.service;

import com.zzgc.common.entity.Student;
import com.zzgc.modules.param.AddStudentParam;
import com.zzgc.modules.param.ExportStudentTemplate;
import com.zzgc.modules.param.ImportStudentTemplate;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;

import java.util.List;

/**
 * 学校学生(Student)表服务接口
 *
 * @author makejava
 * @since 2022-12-05 14:32:14
 */
public interface StudentService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    Student queryById(Long id);

    /**
     * 分页查询
     *
     * @param student 筛选条件
     * @return 查询结果
     */
    List<Student> queryByPage(Student student);

    /**
     * 导出数据
     *
     * @param student 筛选条件
     * @return 查询结果
     */
    List<ExportStudentTemplate> queryByPageExport(Student student);

    /**
     * 新增数据
     *
     * @param student 实例对象
     * @return 实例对象
     */
    Student insert(Student student);

    long count(Student student);

    /**
     *  查询指定区县学生总数
     * @Author
     * @Description
     * @Date  2024/5/15 14:35
     * @Param
     * @return
     */
    long countByDepartId(Long departId, String year);

    /**
     * 新增多条数据
     *
     * @param studentTemplate 实例对象
     * @return 实例对象
     */
    int insertList(String userName,String userId, Long schoolId, String studentTable, List<AddStudentParam> studentTemplate);

    /**
     * 修改数据
     *
     * @param student 实例对象
     * @return 实例对象
     */
    Student update(Student student);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Long id);

}
